<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>08 计算属性</title>
</head>
<body>
  <div id="app">
    <input type="text" v-model="msg">
    {{ msg }}
    <!-- 简单表达式 - 代码执行三次 -->
    <h1>表达式</h1>
    {{ msg.split('').reverse().join('') }}
    {{ msg.split('').reverse().join('') }}
    {{ msg.split('').reverse().join('') }}
    <h1>函数</h1>
    <!-- 函数 - 代码执行三次 -->
    {{ reverseMsgFn() }}
    {{ reverseMsgFn() }}
    {{ reverseMsgFn() }}
    <h1>计算属性</h1>
    {{ reverseMsg }}
    {{ reverseMsg }}
    {{ reverseMsg }}
  </div>
</body>
<script src="lib/vue.js"></script>
<script>
  new Vue({
    el: '#app',
    data: {
      msg: 'hello vue'
    },
    computed: {
      reverseMsg () {
        console.log('reverseMsg')
        return this.msg.split('').reverse().join('')
      }
    },
    methods: {
      reverseMsgFn () {
        console.log('reverseMsgFn')
        return this.msg.split('').reverse().join('')
      }
    }
  })
</script>
</html>
